<template>
  <div class="list-pages white-bg">
    <div class="search-form-box">
      <a-form
        :model="formState"
        name="horizontal_login"
        :label-col="labelCol"
        autocomplete="off"
        @finish="onFinish"
      >
        <a-row :gutter="[16, 16]">
          <a-col :xs="24" :sm="24" :md="12" :lg="12" :xl="12" v-show="expand">
            <a-form-item label="设备" name="keyword">
              <a-input
                v-model:value="formState.keyword"
                placeholder="请输入设备名称/型号/编码"
              >
              </a-input>
            </a-form-item>
          </a-col>
          <a-col :xs="24" :sm="24" :md="12" :lg="6" :xl="6" v-show="expand">
            <a-form-item label="设备状态" name="device_status">
              <a-select
                v-model:value="formState.device_status"
                placeholder="请选择"
              >
                <a-select-option
                  v-for="(item, index) in statusOptions"
                  :key="index"
                  :value="item.value"
                  >{{ item.text }}</a-select-option
                >
              </a-select>
            </a-form-item>
          </a-col>
          <a-col :xs="24" :sm="24" :md="12" :lg="6" :xl="6">
            <a-form-item>
              <div class="search-btn-box" :class="{ pt: expand }">
                <a-button
                  :icon="h(SearchOutlined)"
                  type="primary"
                  html-type="submit"
                  class="search-btn"
                  >查询</a-button
                >
                <a-button
                  :icon="h(ReloadOutlined)"
                  class="reset-btn"
                  @click="resetForm"
                  >清空</a-button
                >
                <a
                  class="expand-btn"
                  style="font-size: 12px; margin-left: 12px"
                  @click="expand = !expand"
                >
                  <template v-if="expand">
                    <UpOutlined />
                  </template>
                  <template v-else>
                    <DownOutlined />
                  </template>
                  {{ expand ? "收起查询" : "展开查询" }}
                </a>
              </div>
            </a-form-item>
          </a-col>
        </a-row>
      </a-form>
    </div>
    <div class="opt-button-box">
      <a-button type="primary" class="btn" @click="handleAdd">
        <img src="/icons/common/icon-add.png" class="icon" />新增设备</a-button
      >
    </div>
    <div class="table-wrapper" ref="tableRef">
      <a-table
        class="table-box"
        row-key="index"
        :columns="columns"
        :dataSource="tableData"
        :loading="loading"
        :row-class-name="
          (_record, index) => (index % 2 === 1 ? 'table-striped' : null)
        "
        sticky
        :scroll="{ y: true, x: 1300 }"
        :pagination="pagination"
        @change="onChange"
      >
        <template #bodyCell="{ column, record }">
          <template v-if="column.dataIndex == 'device_status_id'">
              {{ statusOptions.find((item) => item.value == record[column.dataIndex])?.text }}
          </template>
          <template v-if="column.dataIndex == 'operation'">
            <a-button type="link" class="link" @click="handleDetail(record)">
              查看
            </a-button>
            <a-button type="link" class="link" @click="handleEdit(record)">
              编辑
            </a-button>
            <a-button type="link" class="link" @click="handleSend(record)">
              推送升级包
            </a-button>
            <a-popconfirm title="确认删除?" @confirm="handleDelete(record)">
              <a-button type="link" class="link"> 删除 </a-button></a-popconfirm
            >
          </template>
        </template>
      </a-table>
    </div>
  </div>
</template>
<script setup>
import { ref, computed, h, onMounted, onUnmounted } from "vue";
import {
  SearchOutlined,
  ReloadOutlined,
  DownOutlined,
  UpOutlined,
} from "@ant-design/icons-vue";
import { Modal, message } from "ant-design-vue";
import { useRouter } from "vue-router";
import { useGlobalStore } from "@/store/modules/global";
import API from "@/api/operation";
import columns from "./columns";
const store = useGlobalStore();
const router = useRouter();
const labelCol = { style: { width: "80px" } };

const formState = ref({
  keyword: "",
  device_status: null,
});
const resetForm = () => {
  formState.value = {
    keyword: "",
    device_status: null,
  };
  getData();
};
const windowWidth = ref(window.innerWidth);
const expand = ref(true);

function onFinish(values) {
  console.log("Success:", values);
  getData();
}
const tableData = ref([
  
]);



const onChange = (page) => {
  console.log(page);
  current.value = page.current;
  pageSize.value = page.pageSize;
};
const current = ref(1);
const pageSize = ref(10);
const total = ref(0);
const pagination = computed(() => ({
  position: ["bottomCenter"],
  total: total.value,
  current: current.value,
  pageSize: pageSize.value,
  showSizeChanger: true,
  size: "large",
  showTotal: (total) => `共 ${total} 条`,
}));
// 表格数据获取方法
const getData = async () => {
  let params = {
    current: current.value,
    pageSize: pageSize.value,
    keyword: formState.value.keyword,
    device_status_idArray: formState.value.device_status!==null?[formState.value.device_status]:null,
  };
  const res = await API.DevicePagedList({
    args: params,
  });
  tableData.value = res.data.map(item=>{
    return {
      ...item,
      status: '使用中',
      khmc: '客户名称',
      jxsmc: '经销商'
    }
  });
  total.value = res.total;
};
const handleAdd = () => {
  store.setSubTitle("新增设备");
  router.push("equipment-equipment-option");
};

const handleDetail = (data) => {
  store.setSubTitle("查看设备信息");
  console.log(data.device_id,'当前设备')
  router.push(`equipment-equipment-detail?id=${data.device_id}`);
};
const handleEdit = (data) => {
  console.log("编辑客户", data);
  store.setSubTitle("编辑设备");
  router.push(`equipment-equipment-option?id=${data.device_id}`);
};
const handleSend = (data) => {
  message.warn("对接设备物联网信息后才可以远程升级");
}

const handleDelete = (data) => {
  Modal.confirm({
    title: '确认删除',
    content: `确定要删除设备 "${data.name}" 吗？`,
    okText: '确定',
    cancelText: '取消',
    onOk: async () => {
      try {
        await API.DeviceDelete({ device_id: data.device_id });
        message.success('删除成功');
        await getData();
      } catch (error) {
        console.error('删除设备失败', error);
        message.error('删除失败');
      }
    },
  });
};
const statusOptions = ref([
  { value: 0, text: '在售' },
  { value: 1, text: '停售' }
]);
const getStatusData = async () => {
  // 使用固定的状态选项，不再从API获取
  // const res = await API.DeviceStatusOptions({});
  // statusOptions.value = res;
};
onMounted(async () => {
  windowWidth.value = window.innerWidth;
  if (windowWidth.value > 768) {
    expand.value = true;
  } else {
    expand.value = false;
  }
  window.addEventListener("resize", () => {
    windowWidth.value = window.innerWidth;
    if (windowWidth.value > 768) {
      expand.value = true;
    } else {
      expand.value = false;
    }
  });
  await getData();
  // await getStatusData(); // 不再需要从API获取状态数据
});
onUnmounted(() => {
  window.removeEventListener("resize", () => {});
});
</script>
<style lang="less" scoped>
.list-pages {
  height: 100%;
  padding: 0 16px;
  display: flex;
  flex-direction: column;
  .search-box {
    display: flex;
    align-items: center;
    padding: 18px 0;
    flex-wrap: wrap;
    border-bottom: 1px solid #e5e7eb;
    .search-select {
      width: 120px;
    }
    .line {
      width: 1px;
      height: 16px;
      margin: 0 12px;
      background: #bec4ca;
      @media screen and (max-width: 768px) {
        display: none;
      }
    }
    .search-input-box {
      flex: 1;
      display: flex;
      align-items: center;
      @media screen and (max-width: 768px) {
        width: 100%;
        margin-top: 16px;
        justify-content: space-between;
      }
    }
    .search-input {
      flex: 1;
    }
    .search-btn {
      width: 60px;
      height: 32px;
      background: #2776ff;
      border-radius: 4px;
      font-family: PingFangSC-Regular;
      font-weight: 400;
      font-size: 14px;
      color: #ffffff;
      text-align: center;
      line-height: 32px;
    }
  }
  .table-wrapper {
    width: 100%;
    flex: 1;
    overflow: hidden;
    .table-box {
      height: 100%;
    }
  }
  .list-box {
    width: 100%;
    box-sizing: border-box;
    padding-top: 16px;
    overflow: auto;
    display: grid;
    gap: 16px;
    margin: 0 auto;
    grid-template-columns: repeat(auto-fill, minmax(261px, 1fr));
    justify-content: space-between;
    .list-item {
      width: 261px;
      background: #ffffff;
      border: 1px solid #e6ebf1;
      border-radius: 8px;
      box-sizing: border-box;
      padding: 8px;
      margin: auto;
      position: relative;
      cursor: pointer;
      &:hover {
        border: 1px solid #2776ff;
        box-shadow: 12px 12px 12px 0px rgba(39, 118, 255, 0.1);
      }
      .item-collect {
        position: absolute;
        top: 0;
        right: 0;
        cursor: pointer;
        width: 32px;
        height: 32px;
        background: rgba(0, 0, 0, 0.4) url(@/assets/icon-collet.png) no-repeat
          center center;
        border-radius: 0 8px 0 12px;
        &.cur {
          background: #ffffff url(@/assets/icon-collet-cur.png) no-repeat center
            center;
          border-radius: 0 8px 0 12px;
        }
      }

      .list-img {
        width: 245px;
        height: 249px;
        background: #f3f3f3;
        border: 1px solid #e6ebf1;
        border-radius: 8px;
        box-sizing: border-box;
        img {
          width: 100%;
          height: 100%;
          border-radius: 8px;
        }
      }
      .list-content {
        padding: 14px 0 6px;
        display: flex;
        flex-direction: column;
        .content-title {
          font-family: PingFangSC-Medium;
          font-weight: 500;
          font-size: 16px;
          color: #31323a;
          margin-bottom: 10px;
          line-height: 24px;
          overflow: hidden;
          text-overflow: ellipsis;
          white-space: nowrap;
        }
        .content-col {
          display: flex;
          align-items: center;
          justify-content: space-between;
          .col-user {
            display: flex;
            align-items: center;
            .user-img {
              width: 26px;
              height: 26px;
              border-radius: 50%;
            }
            .user-name {
              font-family: PingFangSC, PingFang SC;
              font-weight: 400;
              font-size: 12px;
              color: #262626;
              line-height: 16px;
              text-align: left;
              font-style: normal;
            }
          }
          .col-date {
            font-family: PingFangSC, PingFang SC;
            font-weight: 400;
            font-size: 12px;
            color: #8c8c8c;
            line-height: 16px;
            text-align: center;
            font-style: normal;
          }
        }
      }
    }
  }

  .pagination-box {
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
}
</style>
